Splunkのtimechartコマンドでデータのトレンドを分析・可視化するための基本的な使い方

Splunkのtimechartコマンドでデータのトレンドを分析・可視化するための基本的な使い方

Splunkのtimechartコマンドの使い方とユースケースを紹介します。
Clock Icon2024.09.03

Splunkのtimechartコマンドの使い方とユースケースを紹介します。Splunk のチュートリアルログを使って進めます。

ある程度、どんな動きをするのか知っていただき、普段の運用に活かしていただけるトピックがあればなと思います!

本記事の参考元:Search Reference - timechart | Splunk Docs

timechartコマンドとは?

Splunkのtimechartコマンドは、時系列でデータを集計することができます。これにより、データの時間的な傾向を可視化し、トレンドの把握や異常の検出を期待できます。

timechartコマンドの基本的な使い方

コマンドでは、集計するログと時間間隔を指定します。

構文

| timechart [span=<time-span>] [aggregation_function] <field> by <field>
  • | timechart は、timechart を使うという宣言みたいなものと考えてください。
  • [span=<time-span>] は、時間の粒度を指定します。1時間ごとなら、span=1h などとします。
  • [aggregation_function] は、count、sum、avg、max、min などの関数です。後続の <field> に集計対象のフィールドを指定します。
  • by <field> は、前述の集計したフィールドをさらに細分化するためにカテゴライズするフィールドを指定します。

それでは、この基本構文に沿って様々な使い方を説明します。

単一フィールドの「値」を時系列で集計する

例えば「WEB サーバでリクエストされたコンテンツのサイズを時系列で知りたい」みたいな時は以下の様に書きます。

| timechart sum(size)

splunk_timechart_sakuma_3

timechart コマンドを使うことで行が時間で並んで表示されます。

グラフ化してみましょう。「視覚エフェクト」を選択します。

splunk_timechart_sakuma_3-1

ついでにX軸とY軸の表記を変更します。

splunk_timechart_sakuma_3-2

グラフの数値がいくつか分かる様に「データの値」を入れましょう。

splunk_timechart_sakuma_3-3

この様にエフェクトを編集すると、人が見て把握しやすいグラフに変更できます。

単一フィールドの「値ごと」に時系列で集計する

例えば「status_code ごと時系列で集計した結果を知りたい」みたいな時は以下の様に書きます。

| timechart count by status_code

splunk_timechart_sakuma_4

by の後ろで指定したフィールドが列に並んで表示されます。

「視覚エフェクト」を確認してみましょう。

splunk_timechart_sakuma_4-1

こちらもグラフを変更してみます。並んだ結果をスタックしてみます。

splunk_timechart_sakuma_4-2

バラバラだったグラフをまとめてスッキリ表示することができました。

あるフィールドの値ごとに別のフィールドの値を時系列で集計する

そしたら、これまで扱った2つのフィールドをマージしてみましょう。例えば「時系列で status_code ごとにリクエストの合計サイズがいくつなのか知りたい」みたいな時には以下の様に書きます。

| timechart sum(size) by status_code

splunk_timechart_sakuma_5

時間は行になり、by の後ろのフィールド(status_code)は列になり、size は集計された値としてテーブルの要素として表示されます。

これまでの設定内容を保持して「視覚エフェクト」を入れてみると、ちょっと見づらくなりました。

splunk_timechart_sakuma_5-2

見やすくするために今度は「トレリスレイアウト」を使ってみましょう。

splunk_timechart_sakuma_5-1

トレリスレイアウトにより、各Status_code ごとに分割して理解しやすくなりました。検索対象のデータが多い場合はご検討ください。

時間の間隔を指定する

ここでは、span というオプションを説明します。例えば「1時間ごとに時系列で status_code ごとのリクエストの合計サイズがいくつなのか知りたい」みたいな時に以下のように書きます。

| timechart span=1h sum(size) by status_code

splunk_timechart_sakuma_6

時間を見てみると集計が1時間ごとになされていることが分かります。span は検索の時間範囲で指定した時間ごとにデータを集計するために指定するオプションです。なので、検索の時間範囲を指定することがとても重要になります。

splunk_timechart_sakuma_6-1

そしたら、これも「視覚エフェクト」を使って可視化してみましょう。

splunk_timechart_sakuma_6-2

グラフもきちんと1時間ごとに分割されています。ちなみにグラフはマウスオーバーで特定のデータを確認することができます。

splunk_timechart_sakuma_6-3

timechart で集計された後の数値データを変換してみた

以下の status_code 200 番の列には KB の単位がついています。

splunk_timechart_sakuma_7

これを列のフィールドに付与する方法を説明します。列となるフィールドにマウスカーソルを合わせ、筆マークを選択すると「数をフォーマット」することができます。

splunk_timechart_sakuma_7-1

設定したらバツ閉じしてみると ..

splunk_timechart_sakuma_7-2

数値に KB が表示されます。このまま視覚エフェクトも選択できますので、テーブルとしてもグラフとしても扱うことができます。

まとめ

timechart コマンドの使い方とグラフ化について様々書いてみましたが、いかがでしたでしょうか?

timechart コマンドもちょっと調べると、今回紹介した以外にたくさん使い方がありますので色々と学んでみて次回は応用的なことも書いてみたいです。

今後も、Splunk の活用例を紹介していきますので、ご注目いただけますと幸いです。

Share this article

facebook logohatena logotwitter logo

© Classmethod, Inc. All rights reserved.